# PATENT ABSTRACTS OF JAPAN

(11)Publication number:

2003-115768

(43)Date of publication of application: 18.04.2003

(51)Int.Cl.

HO3M 13/19

HO3M 13/29

H04L 1/00

(21)Application number: 2002-199657

(71)Applicant:

INTERNATL BUSINESS MACH CORP (IBM)

(22)Date of filing:

09.07.2002

(72)Inventor:

ELEFTHERIOU EVANGELOS STAVROS

/Z)Inventor .

GALBRAITH RICHARD L

**OELCER SEDAT** 

(30)Priority

Priority number: 2001 902859

2001 902859 Priori

Priority date: 11.07.2001

Priority country: US

# (54) LOW DENSITY PARITY CHECK ENCODING METHOD AND DEVICE FOR DATA

#### (57)Abstract:

PROBLEM TO BE SOLVED: To provide a parity check matrix connected to an LDPC code having the encoding complexity of a linear time. SOLUTION: This data low density parity check (LDPC) encoding method comprises a step for defining a first M × N parity check matrix, a step for generating a second parity check matrix having M × M triangle part matrix based on the first parity check matrix, and a step for mapping the data to the LDPC code word based on the second parity check matrix. This method is made valid especially for a data communication application, and also may be used for another application such as a data storage.



LEGAL STATUS

[Date of request for examination]

29.07.2002

[Date of sending the examiner's decision of rejection]

[Kind of final disposal of application other than the examiner's decision of rejection or application converted registration]

[Date of final disposal for application]

[Patent number]

3575606

[Date of registration]

16.07.2004

[Number of appeal against examiner's decision of rejection]

[Date of requesting appeal against examiner's decision of rejection]

[Date of extinction of right]

## (19)日本国特許庁(JP)

# (12) 公開特許公報(A)

(11)特許出願公開番号 特開2003-115768 <sup>レ</sup> (P2003-115768A)

最終頁に続く

(43)公開日 平成15年4月18日(2003.4.18)

| (51) Int.Cl.7 | 識別記号 | ΡΙ            | テーマコート*(参考) |
|---------------|------|---------------|-------------|
| H 0 3 M 13/19 |      | H 0 3 M 13/19 | 5 J O 6 5   |
| 13/29         |      | 13/29         | 5 K 0 1 4   |
| H04L 1/00     |      | H 0 4 L 1/00  | Α           |

審査請求 有 請求項の数14 OL (全 13 頁)

| (21)出願番号    | 特顧2002-199657(P2002-199657) | (71)出願人 | 390009531            |
|-------------|-----------------------------|---------|----------------------|
|             |                             |         | インターナショナル・ビジネス・マシーン  |
| (22)出顧日     | 平成14年7月9日(2002.7.9)         |         | ズ・コーポレーション           |
|             |                             |         | INTERNATIONAL BUSIN  |
| (31)優先権主張番号 | 09/902859                   |         | ESS MASCHINES CORPO  |
| (32)優先日     | 平成13年7月11日(2001.7.11)       |         | RATION               |
| (33)優先権主張国  | 米国 (US)                     |         | アメリカ合衆国10504、ニューヨーク州 |
|             |                             |         | アーモンク ニュー オーチャード ロー  |
|             |                             |         | ۴                    |
|             |                             | (74)代理人 | 100086243            |
|             |                             |         | 弁理士 坂口 博 (外2名)       |
|             |                             |         |                      |
|             |                             |         |                      |
|             |                             | I       |                      |

# (54) 【発明の名称】 データの低密度パリティ検査符号化方法および装置

## (57)【要約】 (修正有)

ードにつながるパリティ検査行列を提供すること。 【解決手段】 データの低密度パリティ検査(LDPC)符号化の方法に、第1のM×Nパリティ検査行列を定義するステップと、第1パリティ検査行列に基づいて、M×M三角部分行列を有する第2パリティ検査行列を生成するステップと、第2パリティ検査行列に基づいてデータをLDPC符号語にマッピングするステップとが含まれる。この方法は、データ通信アプリケーションに特に有用であるが、たとえばデータ・ストレージなどの他のアプリケーションでも使用することができる。

【課題】 線形時間の符号化複雑さを有するLDPCコ



#### 【特許請求の範囲】

【請求項1】データの低密度パリティ検査(LDPC) 符号化の方法であって、

1

第1のM×Nパリティ検査行列を定義するステップと、 前記第1のパリティ検査行列に基づいて、三角行列であるM×M部分行列を有する第2のパリティ検査行列を生 成するステップと、

前記第2のパリティ検査行列に基づいて、前記データを LDPC符号語にマッピングするステップと、 を含む方法。

【請求項2】前記第2のパリティ検査行列から4サイクルを除去するステップをさらに含む、請求項1に記載の方法。

【請求項3】前記第1のパリティ検査行列の前記定義が、前記第1のパリティ検査行列の行のサイクリック・シフトを含む、請求項1に記載の方法。

【請求項4】前記M×M部分行列の主対角線に沿った要素に同一の値をセットするステップを含む、請求項1に記載の方法。

【請求項5】データの低密度パリティ検査(LDPC)符号化装置であって、

第1のM×Nパリティ検査行列を定義する手段と、

前記第1のパリティ検査行列に基づいて、三角行列であるM×M部分行列を有する第2のパリティ検査行列を生成する手段と、

前記第2のパリティ検査行列に基づいて、前記データを LDPC符号語にマッピングする手段と、

# を含む装置。

【請求項6】前記第2のパリティ検査行列を生成する手段が、前記第2のパリティ検査行列から4サイクルを除去する手段をさらに含む、請求項5に記載の装置。

【請求項7】前記第1のパリティ検査行列を定義する手段が、前記第1のパリティ検査行列の行をサイクリック・シフトする、請求項5に記載の装置。

【請求項8】前記第1のパリティ検査行列を定義する手段が、前記M×M部分行列の主対角線に沿った要素に同一の値をセットする、請求項5に記載の装置。

【請求項9】データの低密度パリティ検査(LDPC)符号化プログラムであって、前記符号化プログラムが、コンピュータ・システムに、

第1のM×Nパリティ検査行列を定義する手順と、

前記第1のパリティ検査行列に基づいて、三角行列であるM×M部分行列を有する第2のパリティ検査行列を生成する手順と、

前記第2のパリティ検査行列に基づいて、前記データを LDPC符号語にマッピングする手順と、

を実行させるプログラム。

【請求項10】前記第2のパリティ検査行列から4サイクルを除去する手順をさらにコンピュータ・システムに実行させる、請求項9に記載のプログラム。

【請求項11】前記第1のパリティ検査行列の定義が、 前記第1のパリティ検査行列のサイクリック・シフトを 含む、請求項9に記載のプログラム。

2

【請求項12】データの低密度パリティ検査(LDPC)符号化プログラムを格納したコンピュータ読み取り可能な記憶媒体であって、前記符号化プログラムが、コンピュータ・システムに、

第1のM×Nパリティ検査行列を定義する手順と、

前記第1のパリティ検査行列に基づいて、三角行列であ 10 るM×M部分行列を有する第2のパリティ検査行列を生成する手順と、

前記第2のパリティ検査行列に基づいて、前記データを LDPC符号語にマッピングする手順と、

を実行させるプログラムを格納したコンピュータ読み取り可能な記憶媒体。

【請求項13】通信チャネルを介して情報源から受信したデータを送信し、前記データを低密度パリティ検査 (LDPC) 符号語に符号化するデータ通信装置であって、

20 第1のM×Nパリティ検査行列を定義する手段と、 前記第1のパリティ検査行列に基づいて、三角行列であるM×M部分行列を有する第2のパリティ検査行列を生

前記第2のパリティ検査行列に基づいて、前記データを LDPC符号語にマッピングする手段と、

を含むデータ通信装置。

成する手段と、

【請求項14】データ・ストレージ・チャネル内の情報 源から受信したデータを記憶し、前記データを低密度パ リティ検査(LDPC)符号語に符号化するデータ記憶 30 装置であって、

第1のM×Nパリティ検査行列を定義する手段と、

前記第1のパリティ検査行列に基づいて、三角行列であるM×M部分行列を有する第2のパリティ検査行列を生成する手段と、

前記第2のパリティ検査行列に基づいて、前記データを LDPC符号語にマッピングする手段と、

を含むデータ記憶装置。

【発明の詳細な説明】

[0001]

0 【発明の属する技術分野】本発明は、全般的には、データの低密度パリティ検査(LDPC)符号化の方法および装置に関し、具体的には、データ通信および記憶システムのパイナリ変調およびマルチレベル変調のためのLDPC符号語へのデータのマッピングのためのパリティ検査行列に基づくデータのプロック符号化に関する。

[0002]

【従来の技術】「Low-density parity-check codes (ギャラガ (Gallager) 著/MIT Press/米国マサチューセッツ州ケンプリッジ/1963年)」に、メッセージパ50 ッシング・デコーダに基づいて、バイナリ入力加法性白

色ガウス雑音チャネル(AWGN)のチャネル容量に極めて近づくことができることが示された。それから、LDPC符号を多数の実用的な通信チャネルおよび記録チャネル上で容量に非常に近づけることができることが示された。したがって、LDPC符号は、ターポ符号の代替技術と考えられている。特に、LDPC符号は、ターポ符号よりすぐれた漸近性能を示し、エラー・フロアの影響が少なく、デコーダの複雑さと性能の間のさまざまなトレードオフを提供する。LDPC符号の長所は、その復号に使用されるsum-productアルゴリズムの実装があまり複雑でないことである。sum-productアルゴリズムの簡略化パージョン版では、完全なsum-product復号と比較して無視できる程度の復号性能の低下と引き換えに、複雑さが減らされる。

【0003】ハード・ディスクまたはテープ・システム などの磁気記憶アプリケーションの多くでは、情報がバ イナリ形式で記憶される。これらのアプリケーションで は、リード・ソロモン (Reed-Solomon) 外符号に連接 (concatenate) された変調内符号が、書き込まれた情 報の信頼性の高い抽出のために使用される。ターボ符号 およびLDPC符号は、磁気記憶システムの面密度を、 現在の使用可能な磁気コンポーネントの限界まで押し上 げることができる。ハード・ディスクの現在のセクタ・ サイズの制約が符号のブロック長を制限し、高い符号化 率を要求しているにもかかわらず、単純な反復復号方式 によって理論限界の約1.5dB以内に性能を高めるこ とができることが示された。これは、既存のシステムと 比較して重大な利得を表している。高効率LDPC符号 は、磁気記憶システムの外符号として使用される時に、 畳み込み符号またはターボ符号を超える利点を有すると 思われる。たとえば、LDPC符号は、 $10^{-8}$ のエラー 率でエラー・フロアの影響を受けないと思われる。さら に、LDPC符号のパリティ検査行列のまばらさ(spar seness) によって、畳み込み外符号と直列に連接された システムと比較してより複雑でない復号アルゴリズムが もたらされる。また、インターリービングがLDPC符 号に潜在的に組み込まれているので、LDPCエンコー ダとチャネルの間のインターリーバは不要である。磁気 記憶チャネルに関する従来のリード・ソロモン符号に対 するLDPC符号の潜在的な利益は、「Reduced-Comple xity Iterative Decoding of Low Density Parity Chec k Codes for Generalized Partial Response Channels (ミッテルホルツァ (T. Mittelholzer) 、ドラキア

(A. Dholakia) 、およびエレフテリオウ (E. Elefther iou) 共著/IEEE Trans. Magn., 37(2), pp. 721-728/2001年3月)」に記載されている。LDPC符号によって、磁気記憶システムでは、面密度がその究極の限界まで押し上げられると期待される。

【0004】有線伝送システムおよび無線伝送システムを含む多くの通信システムには、伝送信号帯域幅に対す

4

る厳格な制限がある。そのような制限によって、2より多数のレベルを有する信号変調の必要が生じる。多くの従来のシステムでは、そのようなアプリケーションでトレリス符号化変調(TCM)が使用される。しかし、TCMに関連する問題は、それが反復復号に適さないことである。したがって、許容可能な複雑さでの信号品質のさらなる改善は、達成が困難である。

[OOO5] [A turbo TCM scheme with low decoding complexity (Catena Networks Inc. / Temporary Docum ent BI-090, ITU-T Study Group 15, Question 4/イン ド/ゴア/2000年10月23から27日)」、「Pr oposal of decision makingfor turbo coding and repo rt of performance evaluation of proposed TTCM(PCC C) with R-S code and without R-S code (Mitsubishi Electric Corp. / Temporary Document BI-003, ITU-T S tudy Group 15/インド、ゴア/2000年10月23 から27日)」および「Results of the requirements requested in the coding ad hoc report (Vocal Techn ologies Inc. / Temporary Document HC-073, ITU-T Stu dy Group 15, Question 4/カナダ、ハンツビル/20 00年6月31日から8月4日」に、マルチレベルAD SL伝送およびマルチレベルVDSL伝送のターボ符号 化方式が記載されている。これらのターボ符号化技法で は、再帰的な規則正しい形での畳み込みエンコーダの並 列連接 (parallel concatination) による情報ビットの 符号化と、複数の可能なターポ復号技法の1つによる反 復復号が用いられる。「Block product turbo codes fo r G. dmt. bis and G. lite. bis (Globespan Inc. / Tempor ary Document BA-063, ITU-T Study Group 15, Questio n 4/ベルギー、アントワープ/2000年6月19か ら23日)」に、コンポーネントBose-Chaudhuri-Hoequ enghem (BCH) 符号を使用するブロック・プロダクト ・コードおよびChaseアルゴリズムに基づくそのソフト 反復復号のアプリケーションが記載されている。さらな る複雑さが生じるものの、これらの技法はトレリス符号 化に対するある程度の性能強化を提供する。

【0006】「Low-density parity-check codes (ギャラガ (R. G. Gallager) 著/IRE Trans. Info. Theory, vol. IT-8, pp. 21-28/1962年1月)」、「Near 40 Shannon limit performance of low density parity check codes (マッケイ (D. J. C. MacKay) およびニール (R. M. Neal) 共著/Electron. Lett., vol. 32, no. 18, pp. 1645-1646/1996年8月)」、「Good error-correcting codes based on very sparse matrices (マッケイ (D. J. C. MacKay) 著/IEEE Trans.on Inform. Theory, vol. 45, No. 2, pp. 399-431/1999年3月)」および「Reduced complexity iterative decoding of low density parity check codes based on belief propagation (フォッソリア (FOSSORIER, M. P. 50 C.)、ミハルジェビック(MIHALJEVIC, M.) およびイマ

イ (IMAI, H.) 共著/IEEE Trans. Commun., 1999, 47, (5), pp. 673-680)」に記載されている、LDPC符号の代替の符号化技法に関するアプリケーション開発は、これまで無線システムまたはディジタル磁気記録などのバイナリ変調を必要とするアプリケーションに焦点を合わせてきた。しかし、LDPC符号はマルチレベル伝送にも適用することができる。

[0007] Bandwidth efficient low density pari ty check coding using multilevelcoding and interat ive multistage decoding (ナラヤナン (K. R. Narayan an) およびリー (J. Li) 共著/Proc. Int. Symp. on T urbo-Codes、pp. 165-168/フランス、プレスト/20 00年9月)」に、バイナリLDPCプロック符号に基 づくマルチレベル符号化技法が記載されている。この技 法では、ビット・インターリープ式変調または反復マル チステージ復号を伴うマルチレベル符号化に、LDPC プロック符号が使用される。この技法によるビット・イ ンターリープ式LDPC変調の場合、マルチレベル・シ ンボルの選択に使用されるピットのすべてが、LDPC 符号ピットである。マルチレベル符号化に関して、複数 のLDPCプロック符号が、マルチレベル方式のコンポ ーネント・コードとして使用される。この技法は、複数 のLDPCエンコーダ/デコーダを必要とし、特に長い コードまたは大きいコンステレーション・サイズの場合 にかなり実装が複雑となるという短所を有する。

【0008】「Low density parity check coded modul ation for ADSL (Aware Inc./Temporary Document BI-081, ITU-T Study Group 15, Question 4/インド、ゴア/2000年10月23から27日)」にも、バイナリLDPCプロック符号に基づくマルチレベル符号化技法が記載されている。この技法は、TCMに類似するが、畳み込み符号化の代わりにLDPC符号化が使用されることが異なる。具体的に言うと、set partitioningが、TCMで使用されるものと同一の原理に従う。この技法は、追加のBose-Chaudhuri-Hoeguenghem(BCH)符号を必要とし、これによってシステムの複雑になるという短所を有する。また、TCMおよび類似の方式で必要なset partitioningは、軟(ソフト)判定ペースの復号技法について劣悪な性能につながる。

【0009】「Temporary Document RN-25 (ITU Telecommunications Standardization Sector, Study Group 15/米国ニュー・ジャージー/2001年5月21から25日)」に、決定的(deterministic)LDPC方法と、ADSL伝送およびADSL Lite伝送へのそのアプリケーションが記載されている。ここで提案された方法は、例えば、ガウス消去法を使用する、生成行列の事前の計算を必要とする。符号化には、O(N²)個の演算が必要となる。

【0010】送信される情報ピットの組を第1のグループおよび第2のグループに分割するステップと、ブロッ

ク符号を生成するために第1のグループを符号化するス テップと、グレイコード化されたマッピング関数(Gray -coded mapping function) に従ってプロック・コード に依存するシンボルのコンステレーション内のシンボル のサブセットを選択するステップと、グレイコード化さ れたマッピング関数に従って第2のグループに依存する サブセット内のシンボルを選択するステップと、選択さ れたシンボルを送信するステップとを含むマルチレベル ・データ通信の方法が存在する。この方法は、達成可能 な符号化利得に関して優れた性能を提供する。符号化利 得が生じるのは、プロック符号化方式を反復的に復号す ることができ、これによって、トレリス符号化変調と比 較してかなりの性能利得がもたらされるからである。こ の方法の特に好ましい実施形態には、インターリープを 必要としない、単純なsum-productアルゴリズム (SP A) またはその複雑さの低い派生技術を介して復号する ことができるLDPC符号またはシンプル・プロダクト ・コードに基づくマルチレベル符号化方式が含まれる。

【0011】LDPC符号に関連する不利益は、比較的高い符号化の複雑さが必要になることである。LDPC符号語が情報プロックに符号の生成行列(generator matrixof the code)をかけることによって得られる場合、符号化には、O( $N^2$ )個の演算が必要である(Nは符号長を表す)。そのような符号化の手順は「時間的に線形(linear in time)」ではない。さらに、指定されたLDPCパリティ検査行列から符号の生成行列を計算するために、前処理ステップが必要である。生成行列の計算には、ガウス消去法が含まれ、これは、O

(N³) 個の演算を必要とする。前処理は、特定のLD PC検査行列について1回実行され、オフラインで実行 され得るが、パリティ検査行列の系列 (family) の1つ の選択を必要とするアプリケーションに関する復号の時 に、計算コストが極端に高くなる可能性がある。このこ とは、例えば、符号が接続ごとに選択されるxDSLの 場合が該当する。LDPC符号の効率的な符号化に関す る話題は、「Low density parity check codes with se mi-random parity check matrix (ピン (L. Ping) 、レ ウン (W. K. Leung) 、およびファムド (N. Phamdo) 共 著/Electron. Letters, Vol. 35, No. 1, pp. 38-39/ 1999年1月7日)」、「Comparison of constructi ons of irregular Gallager codes (マッケイ (D. J. C. MacKay)、ウィルソン(S. T. Wilson)、およびダ ベイ(M. C. Davey)共著/IEEE Trans. on Communicat ions, Vol. 47, No. 10, pp. 1449-1454/1999年1 0月)」および「Efficient encoding of low-density parity-check codes (リチャードソン (R.Richardson) およびウルパンケ (R. L. Urbanke) 共著/IEEE Trans. on Information Theory, Vol. 47., No. 2, pp. 638-6 56/2001年2月)」に示されている。

50 [0012] [Low density parity check codes with

semi-random parity check matrix (ピン (L. Ping)、 レウン (W. K. Leung) およびファムド (N. Phamdo) 共 著/Electron. Letters, Vol. 35, No. 1, pp. 38-39/ 1999年1月7日)」では、LDPC符号のパリティ 検査行列が、決定的部分 (deterministic part) とラン ダム部分(random part)を含むという意味で「セミラ ンダム」である。決定的部分は、効率的な符号化を可能 にするために、帯状対角線すなわち「ジグザグ」形(ba nd-diagonal or "zig-zag" form) である。パリティ検 査行列の残りは、4サイクルを避けてランダムに作成さ れる。「Comparison of constructions of irregular G allager codes (マッケイ (D. J. C. MacKay) 、ウィル ソン (S. T. Wilson) およびダベイ (M. C. Davey) 共 著/IEEE Trans. on Communications, Vol. 47, No. 1 0, pp. 1449-1454/1999年10月)」および「Effi cient encoding of low-density parity-check codes (リチャードソン (R. Richardson) およびウルバンケ

(R. L. Urbanke) 共著/IEEE Trans. on InformationT heory, Vol. 47., No. 2, pp. 638-656/2001年2月)」では、パリティ検査行列が、やはりランダム構成によって生成され、三角行列(triangular)または「ほぼ三角行列(approximate triangular)」であることが、効率的な符号化を可能にするために課せられる。これらの構成はそれぞれ、線形時間で符号化可能なLDPC符号につながる。しかし、これには、下記を含む複数の短所がある。

(a) ランダムに構成されたパリティ検査符号は、少数のパラメータを介して指定することができない。言い換えると、パリティ検査行列の0でない要素のすべての位置を、個別に与えなければならない。

(b) パリティ検査行列を三角行列またはほぼ三角行列 にするために、しばしば前処理が必要になる。

(c) 得られる符号が、ランダムに構成されたLDPC 符号と比較して低い性能をもたらす。

# [0013]

【発明が解決しようとする課題】線形時間の符号化の複雑さを有するLDPC符号につながるパリティ検査行列を提供することが望ましい。また、完全に決定的(deterministic)であり、少数のパラメータを介して指定できるパリティ検査行列を提供することが望ましい。また、最小量の前処理を必要とするか前処理が不要なパリティ検査行列を提供することが望ましい。

#### [0014]

【課題を解決するための手段】本発明によれば、データの低密度パリティ検査(LDPC)符号化の方法であって、第1のM×Nパリティ検査行列を定義するステップと、第1のM×Nパリティ検査行列に基づいて、三角行列であるM×M部分行列を有する第2のパリティ検査行列に基づいてデータをLDPC符号語にマッピングするステッ

プとを含む方法が提供される。

【0015】この方法には、さらに、第2のパリティ検査行列から4サイクルを除去するステップを含めることができる。代替案では、パリティ検査行列の定義に、最初から4サイクルを除去するために、第1のパリティ検査行列の行のサイクリック・シフトを含めることができる。本発明の好ましい実施形態には、M×M部分行列の主対角線に沿った要素に同一の値をセットするステップが含まれる。

【0016】もう1つの態様から本発明を見ると、第1のM×Nパリティ検査行列を定義する手段と、第1のM×Nパリティ検査行列に基づいて、三角行列であるM×M部分行列を有する第2のパリティ検査行列を生成する手段と、第2のパリティ検査行列に基づいてデータをLDPC符号語にマッピングする手段とを含む、データの低密度パリティ検査(LDPC)符号化装置が提供される。

【0017】もう1つの態様から本発明を見ると、データの低密度パリティ検査(LDPC)符号化プログラムであって、前記符号化プログラムが、コンピュータ・システムに、第1のM×Nパリティ検査行列を定義する手順と、第1のM×Nパリティ検査行列に基づいて、三角行列であるM×M部分行列を有する第2のパリティ検査行列を生成する手順と、第2のパリティ検査行列に基づいて、データをLDPC符号語にマッピングする手順とを実行させるプログラムが提供される。また、そのようなプログラムを格納したコンピュータ読み取り可能な記憶媒体が提供可能であることは勿論である。

【0018】本発明は、通信チャネルを介して情報源から受信したデータを送信し、前記データを低密度パリティ検査(LDPC)符号語に符号化するデータ送信装置であって、第1のM×Nパリティ検査行列を定義する手段と、第1のM×Nパリティ検査行列に基づいて、三角行列であるM×M部分行列を有する第2のパリティ検査行列に基づいて、データをLDPC符号語にマッピングする手段とを含む、データ送信装置にも拡張され得る。

【0019】本発明は、さらに、データ・ストレージ・チャネル内の情報源から受信したデータを記憶し、前記 が一夕が低密度パリティ検査(LDPC)符号語に符号 化され、第1のM×Nパリティ検査行列を定義する手段と、第1のM×Nパリティ検査行列に基づいて、三角行列であるM×M部分行列を有する第2のパリティ検査行列を生成する手段と、第2のパリティ検査行列に基づいて、データをLDPC符号語にマッピングする手段とを含む、データ記憶装置に拡張され得る。

【0020】したがって、提供されるパリティ検査行列は、線形時間の符号化複雑さを有するLDPC符号につながる。そのような行列は、完全に決定的であり、少数のパラメータを介して指定することができる。また、そ

8

のような行列は、最小量の前処理を必要とするか前処理 が不要である。得られるコードの性能は、ランダムに構 成されるLDPC符号と同等またはそれ以上である。

【0021】これから説明する本発明の好ましい実施形 態は、いわゆる「アレイ・コード」についてパリティ検 査行列の構成を使用する。アレイ・コードは、「Array codes (ブラウム (M. Blaum) 、ファレル (P. Farrel 1) およびティルボーグ (H. van Tilborg) 共著/Handb ook of Coding Theory, V. S. Pless and W. C. Huffma n Eds., Elsevier/1998年)」に記載されている。 LDPCパリティ検査行列を得るためのアレイ・コード の構成の直接の適用は、「Array codes as low-density parity-check codes (ファン (J. L. Fan) /Proc. In t. Symp. on Turbo Codes、pp. 543-546/フランス、プ レスト/2000年9月)」および「LDPCcodes for G. dmt.bis and G.lite.bis (エルフテリオウ (E. Elefthe riou) およびエルセール (S. Oelcer) 共著/Internati onal Telecommunication Union, ITU-T, Study Group 15 / Question 4, Temporary Document CF-060/米国フロ リダ州クリアウォーター/2001年1月8から12 日)」に記載されている。最後に述べた2つの参考文献 の符号は、少数のパラメータを介して指定されるが、線 形時間で符号化することはできない。

[0022]

【発明の実施の形態】以下に、例示のみを目的として、 添付図面を参照して本発明の好ましい実施形態を説明す る。

【0023】以下では、

【数 1 】



を「チルダH」と呼称する。

【0024】まず図1を参照すると、本発明の好ましい実施形態には、ディジタル加入者線(DSL)通信チャネルなどの通信チャネル20を介して受信機(図示せず)に接続される送信装置10が含まれる。動作中に、送信装置10は、コンピュータ・システム、携帯電話、固定回線電話、または類似するデータ通信端点などの情報源40から情報ビット30のシーケンスを受信する。送信装置10は、通信チャネル20を介して受信機に送信するために、情報ビット30をシンボル50に変換する。

【0025】図2を参照すると、本発明の特に好ましい 実施形態では、送信装置10に、分割器100、分割器 100に接続されたプロック・エンコーダであるエンコーダ110、およびエンコーダ110と分割器100に 接続されたシンボル・マッパー120が含まれる。パリティ検査行列の行列ジェネレータ160が、エンコーダ 110に接続される。動作中、分割器100は、各変調

の時に、情報源40から通信される情報ビット30の組 を、第1のグループ130および第2のグループ140 に分割する。エンコーダ110は、第2のグループ14 0を符号化して、行列ジェネレータによって供給される パリティ検査行列に基づいてプロック符号150を生成 する。パリティ検査行列は、コード・パラメータ170 に基づいて行列ジェネレータによって生成される。シン ボル・マッパー120は、グレイコード化されたマッピ ング関数に従って、ブロック符号150に依存するシン 10 ポルのコンステレーション内のシンポルのサブセットを 選択する。シンポル・マッパー120は、グレイコード 化されたマッピング関数に従って、第1のグループ13 0に依存する、サブセット内のシンボルも選択する。選 択されたシンポル50が、通信チャネル20を介して受 信機に通信される。分割器100は、シフト・レジスタ または類似する論理機能によって実施することができ る。送信装置10を、(1)ハードワイヤード・ロジッ ク(結線論理)によって、(2)コンピュータ・プログ ラム・コードを用いてプログラムされた汎用プロセッサ 20 /専用ディジタル信号プロセッサによって、または

10

(3) ハードワイヤード・ロジックとコンピュータ・プログラム・コードの組み合わせによって、実施できることに留意されたい。

【0026】図3を参照すると、図2に関して既に本明 細書で説明した送信装置10の変更形態では、分割器100が省略され、エンコーダ110が、情報源40から 受信した情報ビット30のすべてを符号化して、プロック符号150を生成する。シンボル・マッパー120 が、グレイコード化されたマッピング関数に従って、ブ のック符号150に依存するシンボルのコンステレーション内のシンボルを選択する。選択されたシンボル50 が、通信チャネル20を介して受信機に通信される。

【0027】図4を参照すると、本発明の好ましい実施 形態では、行列ジェネレータ160に、三角行列ジェネ レータ310に接続された行列定義ロジック300が含 まれる。図5を参照すると、ステップ350で、動作 中、行列定義ロジック300が、入力のコード・パラメ ータ170に基づいて第1のM×Nパリティ検査行列3 20を定義する。ステップ360で、三角行列ジェネレ 40 ータ310が、第1の行列に基づいて第2の行列を生成 する。第2の行列は、M×Mの三角行列である部分行列 を有する。ステップ370で、第2の行列が、行列ジェ ネレータ160からエンコーダ110に供給される。エ ンコーダ110へのデータ入力が、第2の行列に基づい てLDPC符号語にマッピングされる。本発明の好まし い実施形態でのパリティ検査行列の定義および三角行列 の生成の2つの手法を、図6および図7に関してこれか ら説明する。

【0028】図6を参照すると、本発明の好ましい実施 50 形態では、行列生成に、3つのステップ、1、2、およ

び3が含まれる。ステップ1では、行列Hを、アレイ・コードに関するパリティ検査行列(parity-check matrices for array codes)の定義に従って定義する。ステップ2は、上三角構造(upper-triangular structure)を実現するために行列Hを決定的に修正する三角化(triangularization)ステップである。ステップ3には、第2のステップで導入された可能性がある4サイクルを除去する単純な手順が含まれる。

11

【0029】 <ステップ1: Hの定義 (Definition of H) >アレイ・コード風のLDPCパリティ検査行列H は、3つのパラメータすなわち、素数 p  $\ge 2$  つの整数 k, j (k, j  $\le$  p) によって定義される。行列Hは、次元 j p  $\times$  k p を有し、次式によって与えられる。

【数2】

$$H = \begin{bmatrix} I & I & I & \cdots & I \\ I & a & a^2 & \cdots & a^{k-1} \\ I & a^2 & a^4 & \cdots & a^{2(k-1)} \\ \vdots & \vdots & \vdots & \ddots & \vdots \\ I & a^{j-1} & a^{2(j-1)} & \cdots & a^{(j-1)(k-1)} \end{bmatrix}$$

ここで、Iは、 $p \times p$ 単位行列であり、aは、シングル・レフト(またはライト)・サイクリック・シフトを表す $p \times p$ 置換行列であり、例えば、

【数3】

$$a = \begin{bmatrix} 0 & 1 & 0 & 0 & 0 \\ 0 & 0 & 1 & 0 & 0 \\ 0 & 0 & 0 & 1 & 0 \\ 0 & 0 & 0 & 0 & 1 \\ 1 & 0 & 0 & 0 & 0 \end{bmatrix} \quad \text{$\pm$$$ $\hbar$$ $t$} \quad a = \begin{bmatrix} 0 & 0 & 0 & 0 & 1 \\ 1 & 0 & 0 & 0 & 0 \\ 0 & 1 & 0 & 0 & 0 \\ 0 & 0 & 1 & 0 & 0 \\ 0 & 0 & 0 & 1 & 0 \end{bmatrix}$$

である。パラメータ j , k は、それぞれHの列数および 行数を提供する。構成により、行列Hは、4サイクル・フリー(4サイクルなしの状態)である。言い換えるならば、複数の位置にオーバーラップする1を有する行は ない。

【0030】 Hは、符号語長N=kpとパリティ検査数 M=jpを有するLDPC符号の系列のパリティ検査行列を表す。符号語長N'(<N)またはパリティ検査数 M'(<M)を有するLDPC符号は、Hの右端の(N-N')列および下端の(M-M')行を破棄することによって簡単に得られる。結果として得られる $M' \times N'$ 行列が、使用される行列のサイズの明白な修正と共に、ステップ2および3でHの代わりに使用される。

【0031】 <ステップ2: Hの三角化 (Triangulariz ation of H) > Hが、プロック行列形式

#### $H = [H_1 | H_2]$

で表され、 $H_1$ が、次元j p×j pを有し、 $H_2$ が、次元j p×(k-j) pを有するものとする。Uが、 $H_1$ の主対角線(main diagonal)上の各要素を1 に置換し、

主対角線の下のすべての要素に0をセットすることによって $H_1$ から得られるj p $\times$  j pの上三角行列であるものとする。j p $\times$  k pの行列

12

 $H_{II}=[U\mid H_2]$ 

によって、線形時間で符号化可能なLDPC符号のパリティ検査行列が定義される。

【0032】行列Hが、構成によって4サイクルがないが、Hyが、上三角行列Uを導入したことに起因して、4サイクル・フリーではない場合があることに留意され たい。しかし、4サイクルは、次のステップで示されるように、簡単に検出され、除去される。

【0033】 <ステップ3:4サイクルの除去(Elimin ation of 4-cycles) >A= $H_{IJ}$  ·  $H_{IJ}$  であるものとする。ただし、Tは行列転置を表す。Aの対角要素 $a_{m,m}$ , m=1, …, jpによって、行mのハミング重さ、すなわち、行列 $H_{IJ}$ のパリティ検査mによって検査されるシンボルの数が与えられる。非対角要素 $a_{m,n}$ 、m, n=1, …, jp、 $m\neq n$ によって、パリティ検査mおよびパリティ検査nの両方によって検査されるシンプルの数が与えられる。4サイクルなしでは、 $a_{m,n} \leq 1$ である。

【0034】したがって、パリティ検査行列が4サイクル・フリーであることを保証するためには、(a)  $A = H_{IJ} \cdot H_{IJ}^T$ の下三角部分(lower-triangular part)を計算し、(b)  $a_{III}$ , (m, n=1, …, j p; m <n) の場合に、 $H_{IJ}$ の第(n, m)要素に0をセットする

【0035】チルダHyによって、ステップ3の最後に得られる行列を表す。チルダHyによって定義されるL 30 DPC符号は、符号語長N=kp、パリティ検査数M=jp、および情報プロック長K=(k-j)pを有する。チルダHyを使用することによる線形時間符号化の可能性を、次に示す。

【0036】効率的な符号化は、符号の生成行列を計算する必要なしに、パリティ検査行列チルダ $H_{IJ}$ から直接に達成される。LDPC符号が線形プロック符号なので、Nタプル (N-tuple) x は、Oが $M \times 1$  の零ベクトルであるものとして、チルダ $H_{IJ}$ ・x=0 の場合に限ってLDPC符号語になる。このベクトルx は、次の形で40 表すことができる。

### 【数4】

$$x = \left[\frac{p}{s}\right]$$

ここで、jp×1のペクトルpが、符号語xのパリティ部分、(k-j)p×1のペクトルsが、符号語xの組50 織的部分を表す。pのjp個のパリティ・ピットは、

【数5】

$$\widetilde{H}_{u} \bullet \left[\frac{p}{s}\right] = 0$$

を使用し、チルダ $H_{IJ}$ の上三角形式を使用することによって、再帰的な形で得られる。これを示すために、ベクトルpおよびsの両方が、 $p \times 1$ の部分ベクトルに分割されるものとする。

【数 6 】

$$p = \begin{bmatrix} p_1 \\ p_2 \\ \vdots \\ p_j \end{bmatrix} \qquad \text{$\sharp$ LV} \qquad s = \begin{bmatrix} s_1 \\ s_2 \\ \vdots \\ s_{k-j} \end{bmatrix}$$

【数7】

$$p_{m,p} = \sum_{\ell=m+1}^{j} p_{\ell,\dots} + \sum_{\ell=1}^{k-j} s_{\ell,\dots}$$

$$p_{m,p-1} = (p_{m,p}) + \sum_{\ell=m+1}^{j} p_{\ell,\dots} + \sum_{\ell=1}^{k-j} s_{\ell,\dots}$$

$$\vdots$$

$$p_{m,1} = (p_{m,...}) + \sum_{\ell=m+1}^{j} p_{\ell,...} + \sum_{\ell=1}^{k-j} s_{\ell,...}$$

$$H^{5} = \begin{bmatrix} I & I & I & \cdots & I & I & \cdots & I \\ a^{k-1} & I & a & \cdots & a^{j-2} & a^{j-1} & & a^{k-2} \\ a^{2(k-2)} & a^{2(k-1)} & I & \cdots & a^{2(j-3)} & a^{2(j-2)} & & a^{2(k-3)} \\ \vdots & \vdots & \vdots & \ddots & \vdots & \vdots & & \vdots \\ a^{(j-1)(k-j+1)} & a^{(j-1)(k-j+2)} & \cdots & \cdots & I & a^{j-1} & \cdots & a^{(j-1)(k-1)} \end{bmatrix}$$

 $H^{S}$ は、サイクリック・シフトのみを介してHから得られたので、それぞれ j および k によって与えられる列および行の重さを有し、4 サイクルフリーである。

【0040】<ステップ2': H<sup>S</sup>の三角化(Triangula rization of H<sup>S</sup>)>行列H<sup>S</sup>は、左端のjp×jp個の ここで、第2の添字、 $p_1$ 、…および $s_1$ 、…は、行列aのべきによって割り当てられる特定の値に依存するが、表記が長くならないように省略されたものである。括弧内に示された項は、やはり行列aのべきの特定の値に依存して、実際には存在しない場合がある。

【0037】したがって、上の符号化処理は、パリティ検査行列チルダHyの三角形構造(triangular structure)およびそのまばらさ(sparsity)を利用している。rが符号化率であるものとして、符号化が約

10 【数8】

$$\frac{N}{2}\left[j(1+r)+\left(1-\frac{4}{j}\right)(1-r)\right]$$

回のXOR演算を必要とすることを示すことができる。 【0038】図7を参照すると、図6に関して既に説明 した手法の変更形態に、2つのステップ1、および2、 が含まれる。ステップ1、および2、を、これから詳細 20 に説明する。

【0039】 <ステップ1':  $H^S$ の定義(Definition of  $H^S$ ) >行列 $H^S$ は、プロック単位の形で、行列Hの行をサイクリック・シフトすることによって定義される。各プロック-行のサイクリック・シフトの量は、 $H^S$ の左端の $jp \times jp$ 個のサブ・プロックに、その対角線に沿って単位行列 I が含まれるようになる量である。

30

サブ・ブロックの下三角要素を0 に置換することによって三角化される。その結果、下記の行列 $H_U$ <sup>S</sup>が得られる。

【数10】

$$H_{U}^{S} = \begin{bmatrix} I & I & I & \cdots & I & I & \cdots & I \\ O & I & a & \cdots & a^{j-2} & a^{j-1} & & a^{k-2} \\ O & O & I & \cdots & a^{2(j-3)} & a^{2(j-2)} & & a^{2(k-3)} \\ \vdots & \vdots & \vdots & \ddots & \vdots & \vdots & \vdots \\ O & O & \cdots & O & I & a^{j-1} & \cdots & a^{(j-1)(k-1)} \end{bmatrix}$$

ここで、Oは、p×pの零行列である。

【0041】H<sub>II</sub>Sによって定義されるLDPC符号は、 符号語長N = k p、パリティ検査数M = j p、および情 10 よって、効率的に得ることができる。 報プロック長K = (k - j) pを有する。また、H $\mu^{S}$ は、4サイクル・フリーである。明らかに、 $H\mu^{S}$ によ って定義されるLDPC符号は、線形時間での符号化が 可能である。

【0042】符号語長N'(<N)またはパリティ検査 数M'(<M)を有するLDPC符号は、H<sub>II</sub>Sの右端の (N-N')列および下端の(M-M')行を破棄する ことによって、簡単に得られる。

【0043】効率的な符号化は、図6に関して前に説明 した手法に関して前に説明したものと同一の形で達成さ 20 れる。 r が符号化率であるものとして、

【数11】

$$\frac{N}{2}[r(j+3)+(j-3)]$$

回のXOR演算が必要であることを示すことができる。 【0044】図6および7に関して本明細書で前に説明 した本発明の実施形態で得られるパリティ検査行列は、 三角行列を有する。「Comparison of constructions of 30 irregular Gallager codes (マッケイ (D. J. C. MacK ay)、ウィルソン(S. T. Wilson) およびダベイ(M. C. Davey) 共著/IEEE Trans. on Communications, Vo 1. 47, No. 10, pp. 1449-1454/1999年10月)」 と、「Efficient encoding of low-density parity-che ck codes/リチャードソン (R. Richardson) およびウ ルバンケ (R. L. Urbanke) 共著/IEEE Trans. on Info rmation Theory, Vol. 47., No. 2, pp. 638-656 \( 2 \) 0 1年2月)」に、「ほぼ三角形」の形

【数12】

$$egin{bmatrix} C & D \ T & E \end{bmatrix}$$

(C、D、E、およびTは適当な次元の行列であり、T 行列が上三角行列である。) のパリティ検査行列を有す るLDPC符号についても、高速な符号化が可能である ことが示されている。そのような形は、図6および7に 関して本明細書で前に説明した手法を一般化することに

【0045】たとえば、図6に関して本明細書で前に説 明した手法に従う場合には、ほぼ三角行列を生成するた めに、ステップ1は同一のままであるが、行列Hを、ブ ロック行列形式で

【数13】

$$H = \begin{bmatrix} H_3 & H_4 \\ H_5 & H_6 \end{bmatrix}$$

として同等に記述することができる。ここで、H5は、 t p×t pの行列であり、整数 t ≦j であり、行列 H<sub>3</sub>、H<sub>4</sub>、およびH<sub>6</sub>は、適当な次元を有する。ステッ プ2に類似する三角化ステップを、H5に適用する。U5 が、H5の主対角線の各要素を1に置換し、主対角線の 下のすべての要素に0をセットすることによってH5か ら得られる tp×tp上三角行列であるものとする。

【0046】jp×kpの行列

【数14】

$$egin{bmatrix} H_3 & H_4 \ U_5 & H_6 \end{bmatrix}$$

は、ほぼ三角行列であり、したがって、これによって、 前述の「Comparison ofconstructions of irregular Ga 40 llager codes (マッケイ (D. J. C. MacKay) 、ウィル ソン (S. T. Wilson) およびダベイ (M. C. Davey) 共 著/IEEE Trans. on Communications, Vol. 47, No. 1 0, pp. 1449-1454/1999年10月)」と、「Effici ent encoding of low-density parity-check codes () チャードソン (R. Richardson) およびウルバンケ (R. L. Urbanke) 共著/IEEE Trans. on Information Theor y, Vol. 47., No. 2, pp.638-656/2001年2月)」 による高速な符号化が可能なLDPC符号のパリティ検 査行列が定義される。その後、ステップ3をこのほぼ三 50 角形の行列に適用して、4サイクルを除去する。

【0047】明らかに、ステップ1の行列Hを、行方向および列方向に切り詰めて、符号語長およびパリティ検査数の特定の値を実現することができる。

【0048】前に示したように、図7に関して本明細書 で前に説明した手法も、ほぼ三角形のパリティ検査行列 を得るのに使用することができる。この目的のために **は、行列H<sup>S</sup>の t - 1 個の下側ブロック行を右にサイク** リック・シフトすることによって、ステップ1'を変更 する。すなわち、最も下のプロック行が、 t-1位置だ けシフトされ、次に上のプロック行が、 t-2位置だけ シフトされる。その後、ステップ2'を、そのようにし て得られた行列の左下のtp×tp部分行列だけに適用 して、ほぼ三角形の新しい行列をもたらす。行列全体 が、ほぼ三角行列であり、4サイクルがなく、「Compar ison of constructions of irregular Gallager codes (マッケイ (D. J. C. MacKay) 、ウィルソン (S. T. ₩ ilson)、およびダベイ (M. C. Davey) 共著/IEEE Tra ns. on Communications, Vol. 47, No. 10, pp. 1449-14 54/1999年10月)」と、「Efficient encoding o f low-density parity-check codes (リチャードソン (R. Richardson) およびウルバンケ (R. L. Urbanke) 共著/IEEE Trans. on Information Theory, Vol. 47., No. 2, pp.638-656/2001年2月)」に従う高速L DPC符号化に直接に使用することができる。

【0049】やはり、ステップ2'の終りに得られる行 列を、行方向および列方向に切り詰めて、符号語長およ びパリティ検査数の特定の値を達成することができる。 【0050】本発明のいくつかの実施形態では、パリテ ィ検査行列を、通信チャネル20を介する受信機への送 信装置10の接続の際に、行列定義ロジック300によ って定義することができる。たとえば、行列を、通信チ ャネル20の端点間で折衝された次元に基づいて、接続 時に行列定義ロジック300によって作成することがで きる。具体的に言うと、パリティ検査行列を、受信機か ら送信装置10へのコード・パラメータ170の供給に 基づいて決定することができる。本発明の他の実施形態 では、パリティ検査行列を、接続が確立される前に、行 列定義ロジック300によって定義することができる。 たとえば、1つまたは複数のパリティ検査行列を、行列 定義ロジック300内で事前設定することができ、各事 前設定された行列が、事前設定されたコード長(列数) および事前設定されたパリティ検査数(行数)を有す

【0051】本発明の好ましい実施形態を、これまでは 通信システムに関して説明した。しかし、本発明は、そ のようなシステムへの適用に制限されない。たとえば、

る。複数の事前設定された行列を有する実施形態では、 接続の確立時に、適当な行列が、行列定義ロジック30

0に対して選択される。そのような選択は、たとえば、

前に説明したように通信チャネル20の端点間の折衝に

基づいて実行することができる。

図8を参照すると、前に説明したエンコーダ110の実施形態を、情報源40からのデータをハード・ディスク・ストレージ・チャネルなどのストレージ・チャネルに記憶するデータ記憶システム210で使用することもできる。

18

【0052】本明細書で前に説明した送信装置10、エ ンコーダ110、および行列ジェネレータ160のそれ ぞれを、(1)ハードワイヤード・ロジックによって、 (2) コンピュータ・プログラム・コードを用いてプロ 10 グラムされた汎用プロセッサ/専用ディジタル信号プロ セッサによって、または(3)ハードワイヤード・ロジ ックとコンピュータ・プログラム・コードの組み合わせ によって、実施できることを諒解されたい。たとえば、 図9を参照すると、前に図2に関して説明したデータ通 信システムで、送信装置10に、メモリ410に接続さ れたプログラマブル・ディジタル信号プロセッサ(DS P) 400を含めることができ、メモリ410にコンピ ュータ・プログラム・コード420が記憶され、コンピ ュータ・プログラム・コード420が、DSP400に 20 よって実行される時に、図5に関して前に説明した方法 のステップを実行するようにDSP400を構成する。

【0053】本明細書で好ましい実施形態に関して本発明を説明したが、当業者は、本発明の範囲から逸脱せずに、形態および詳細におけるさまざまな変更を行うことができることを諒解するであろう。

【0054】まとめとして、本発明の構成に関して以下の事項を開示する。

【0055】(1)データの低密度パリティ検査(LDPC)符号化の方法であって、第1のM×Nパリティ検査行列を定義するステップと、前記第1のパリティ検査行列に基づいて、三角行列であるM×M部分行列を有する第2のパリティ検査行列を生成するステップと、前記第2のパリティ検査行列に基づいて、前記データをLDPC符号語にマッピングするステップと、を含む方法。

- (2)前記第2のパリティ検査行列から4サイクルを除去するステップをさらに含む、上記(1)に記載の方は
- (3) 前記第1のパリティ検査行列の前記定義が、前記 第1のパリティ検査行列の行のサイクリック・シフトを 40 含む、上記(1)に記載の方法。
  - (4) 前記M×M部分行列の主対角線に沿った要素に同一の値をセットするステップを含む、上記(1) に記載の方法
- (5) データの低密度パリティ検査(LDPC)符号化装置であって、第1のM×Nパリティ検査行列を定義する手段と、前記第1のパリティ検査行列に基づいて、三角行列であるM×M部分行列を有する第2のパリティ検査行列を生成する手段と、前記第2のパリティ検査行列に基づいて、前記データをLDPC符号語にマッピング50 する手段と、を含む装置。

- (6) 前記第2のパリティ検査行列を生成する手段が、 前記第2のパリティ検査行列から4サイクルを除去する 手段をさらに含む、上記(5)に記載の装置。
- (7) 前記第1のパリティ検査行列を定義する手段が、 前記第1のパリティ検査行列の行をサイクリック・シフ トする、上記(5)に記載の装置。
- (8) 前記第1のパリティ検査行列を定義する手段が、 前記M×M部分行列の主対角線に沿った要素に同一の値 をセットする、上記(5)に記載の装置。
- (9) データの低密度パリティ検査(LDPC)符号化 10 プログラムであって、前記符号化プログラムが、コンピュータ・システムに、第1のM×Nパリティ検査行列を定義する手順と、前記第1のパリティ検査行列に基づいて、三角行列であるM×M部分行列を有する第2のパリティ検査行列を生成する手順と、前記第2のパリティ検査行列に基づいて、前記データをLDPC符号語にマッピングする手順と、を実行させるプログラム。
- (10) 前記第2のパリティ検査行列から4サイクルを 除去する手順をさらにコンピュータ・システムに実行さ せる、上記(9) に記載のプログラム。
- (11) 前記第1のパリティ検査行列の定義が、前記第 1のパリティ検査行列のサイクリック・シフトを含む、 上記(9) に記載のプログラム。
- (12) データの低密度パリティ検査(LDPC)符号 化プログラムを格納したコンピュータ読み取り可能な記憶媒体であって、前記符号化プログラムが、コンピュータ・システムに、第1のM×Nパリティ検査行列を定義する手順と、前記第1のパリティ検査行列に基づいて、三角行列であるM×M部分行列を有する第2のパリティ検査行列を生成する手順と、前記第2のパリティ検査行列を基づいて、前記データをLDPC符号語にマッピングする手順と、を実行させるプログラムを格納したコンピュータ読み取り可能な記憶媒体。
- (13)通信チャネルを介して情報源から受信したデータを送信し、前記データを低密度パリティ検査(LDP C)符号語に符号化するデータ通信装置であって、第1のM×Nパリティ検査行列を定義する手段と、前記第1のパリティ検査行列に基づいて、三角行列であるM×M部分行列を有する第2のパリティ検査行列を生成する手段と、前記第2のパリティ検査行列に基づいて、前記デ 40ータをLDPC符号語にマッピングする手段と、を含むデータ通信装置。
- (14) データ・ストレージ・チャネル内の情報源から 受信したデータを記憶し、前記データを低密度パリティ

検査(LDPC)符号語に符号化するデータ記憶装置であって、第1のM×Nパリティ検査行列を定義する手段と、前記第1のパリティ検査行列に基づいて、三角行列であるM×M部分行列を有する第2のパリティ検査行列を生成する手段と、前記第2のパリティ検査行列に基づいて、前記データをLDPC符号語にマッピングする手段と、を含むデータ記憶装置。

20

#### 【図面の簡単な説明】

- 【図1】通信システムのブロック図である。
- 【図2】通信システムの送信装置のプロック図である。
  - 【図3】通信システムのもう1つの送信装置のブロック図である。
  - 【図4】送信装置の行列ジェネレータのブロック図である。
  - 【図5】送信装置のエンコーダ機能に対応する流れ図である。
  - 【図6】行列ジェネレータに対応する流れ図である。
  - 【図 7 】行列ジェネレータに対応するもう 1 つの流れ図 である。
- 20 【図8】データ記憶システムのブロック図である。
  - 【図9】通信システムの送信装置のもう1つの例のブロック図である。

#### 【符号の説明】

- 10 送信装置
- 20 通信チャネル
- 30 情報ビット
- 40 情報源
- 50 シンボル
- 100 分割器
- 0 110 エンコーダ
  - 120 シンボル・マッパー
  - 130 第1のグループ
  - 140 第2のグループ
  - 150 ブロック・コード
  - 160 行列ジェネレータ
  - 170 コード・パラメータ
  - 210 データ記憶システム
  - 300 行列定義ロジック
  - 310 三角行列ジェネレータ
- 0 320 第1のM×Nパリティ検査行列
  - 400 プログラマブル・ディジタル信号プロセッサ (DSP)
  - 410 メモリ
  - 420 コンピュータ・プログラム・コード





# フロントページの続き

- (72)発明者 エバンゲロス・スタフロス・エレフセリウ スイス8038 チューリッヒ ベラリアシュ トラーセ 53
- (72)発明者 リチャード・レオ・ガルプレイス アメリカ合衆国55902 ミネソタ州ロチェ スター ウェンデー・レーン サウス・ウェスト 5225
- (72)発明者 セダト・ウルサー スイス シーエイチ-8804 アウ アプフ ェルマッテ 17
- F ターム(参考) 5J065 AA01 AA03 AB01 AC02 AC03 AD02 AD06 AE06 AF03 AH01 AH06 5K014 AA01 BA02